<template>
    <div :class="classes">
        <template v-if="uiStyle=='STYLE2'">
            <app-form-group2
                :caption="caption"
                :uiStyle="uiStyle"
                :layoutType="layoutType"
                :isShowCaption="isShowCaption"
                :uiActionGroup="uiActionGroup"
                :titleBarCloseMode="titleBarCloseMode">
                   <slot></slot>
                </app-form-group2>
        </template>
        <template v-else>
            <card v-if="isShowCaption === true" :bordered="false" :dis-hover="true" :class="classes">
                <p :class="titleClass" slot='title'>
                     <icon v-if="titleBarCloseMode !== 0" :type="collapseContant ? 'ios-arrow-dropright-circle' : 'ios-arrow-dropdown-circle'"
                    @click="clickCollapse"></icon>
                      <i v-if="iconInfo && iconInfo.cssClass" :class="iconInfo.cssClass" style="margin-right: 4px;" />
                      <img v-else-if="iconInfo && iconInfo.imagePath" :src="iconInfo.imagePath" style="margin-right: 4px;" alt="">
                      <span>{{caption}}</span>
                </p>
                <template slot='extra'>
                    <template v-if="uiActionGroup">
                    <span class="ui-actions">
                        <a>
                            <template v-if="uiActionGroup.extractMode && Object.is(uiActionGroup.extractMode, 'ITEMS')">
                                <dropdown :transfer="true" trigger='click'>
                                <a href='javascript:void(0)'>
                                    {{uiActionGroup.caption}}
                                </a>
                                <dropdown-menu slot='list' v-if="uiActionGroup.details && Array.isArray(uiActionGroup.details)">
                                    <dropdown-item v-for="(detail,index) in (uiActionGroup.details)" :key="index" :name="detail.name">
                                        <span class='item' v-show="detail.visabled" :style="{'pointer-events':detail.disabled?'none':'auto','color':detail.disabled?'#7b7979':'#2d8cf0'}" @click="doUIAction($event, detail)">
                                            <template v-if="detail.isShowIcon">
                                                <template v-if="detail.icon && !Object.is(detail.icon, '')">
                                                    <i :class="detail.icon" ></i>
                                                </template>
                                                <template v-if="!(detail.icon && !Object.is(detail.icon, ''))">
                                                    <div v-if="detail.img && !Object.is(detail.img, '')">
                                                        <img :src="detail.img" />
                                                    </div>
                                                </template>
                                            </template>
                                            &nbsp;
                                            <span>
                                                <template v-if="detail.isShowCaption">
                                                    <template v-if="uiActionGroup.langbase && !Object.is(uiActionGroup.langbase, '') && detail.uiactiontag && !Object.is(detail.uiactiontag, '')">
                                                        {{$t(`${uiActionGroup.langbase}.uiactions.${detail.uiactiontag}`)}}
                                                    </template>
                                                    <template v-if="!(uiActionGroup.langbase && !Object.is(uiActionGroup.langbase, '') && detail.uiactiontag && !Object.is(detail.uiactiontag, ''))">
                                                        {{detail.caption}}
                                                    </template>
                                                </template>
                                            </span>
                                        </span>
                                    </dropdown-item>
                                </dropdown-menu>
                            </dropdown>
                            </template>
                            <template v-if="!(uiActionGroup.extractMode && Object.is(uiActionGroup.extractMode, 'ITEMS'))">
                                <span class='item-extract-mode'>
                                    <template v-if="uiActionGroup.details && Array.isArray(uiActionGroup.details)">
                                        <div v-for="(detail,index) in uiActionGroup.details" :key="index">
                                            <span v-show="detail.visabled" :style="{'pointer-events':detail.disabled?'none':'auto','color':detail.disabled?'#7b7979':'#2d8cf0'}" class='item' @click="doUIAction($event, detail)">
                                                <template v-if="detail.isShowIcon">
                                                    <template v-if="detail.icon && !Object.is(detail.icon, '')">
                                                        <i :class="detail.icon" ></i>
                                                    </template>
                                                    <template v-if="!(detail.icon && !Object.is(detail.icon, ''))">
                                                        <div v-if="detail.img && !Object.is(detail.img, '')">
                                                            <img :src="detail.img" />
                                                        </div>
                                                    </template>
                                                </template>
                                            &nbsp;
                                            <span>
                                                <template v-if="detail.isShowCaption">
                                                    <template v-if="uiActionGroup.langbase && !Object.is(uiActionGroup.langbase, '') && detail.uiactiontag && !Object.is(detail.uiactiontag, '')">
                                                        {{$t(`${uiActionGroup.langbase}.uiactions.${detail.uiactiontag}`)}}
                                                    </template>
                                                    <template v-if="!(uiActionGroup.langbase && !Object.is(uiActionGroup.langbase, '') && detail.uiactiontag && !Object.is(detail.uiactiontag, ''))">
                                                        {{detail.caption}}
                                                    </template>
                                                </template>
                                            </span>
                                        </span>
                                        </div>
                                    </template>
                                </span>
                            </template>
                        </a >
                    </span>
                    </template>
                    <slot name="dataInfoPanel"></slot>
                </template>
                <template v-if="Object.is(layoutType, 'FLEX')">
                    <slot></slot>
                </template>
                <template v-if="!Object.is(layoutType, 'FLEX')">
                    <row :gutter="10"><slot></slot></row>
                </template>
                <template v-if="isManageContainer">
                    <i-button type="primary" :icon="manageContainerStatus?'ios-repeat':'ios-more'" @click="doManageContainer">
                        {{manageContainerStatus?$t('components.appformgroup.hide'):$t('components.appformgroup.showmore')}}
                    </i-button>
                </template>
            </card>
            <template v-if="isShowCaption === false">
                <slot></slot>
            </template>
        </template>
    </div>
</template>

<script lang="ts">
import { Vue, Component, Prop } from 'vue-property-decorator';

@Component({})
export default class AppFormGroup extends Vue {

    /**
     * 标题
     *
     * @type {string}
     * @memberof AppFormGroup
     */
    @Prop() caption?: string;

    /**
     * 注入数据
     *
     * @type {*}
     * @memberof AppFormGroup
     */
    @Prop() data!: any;

    /**
     * 是否为管理容器
     *
     * @type {string}
     * @memberof AppFormGroup
     */
    @Prop({ default: false }) isManageContainer?: boolean;
    
    /**
     * 管理容器状态
     *
     * @type {string}
     * @memberof AppFormGroup
     */
    @Prop({ default: false }) manageContainerStatus?: boolean;

    /**
     * 内置界面样式
     * 
     * @type {string}
     * @memberof AppFormGroup
     */
    @Prop() uiStyle?: string;

    /**
     * 布局模式
     *
     * @type {string}
     * @memberof AppFormGroup
     */
    @Prop() layoutType?: string;

    /**
     * 标题样式
     *
     * @type {string}
     * @memberof AppFormGroup
     */    
    @Prop() titleStyle?:string;

    /**
     * 分组图标
     *
     * @type {string}
     * @memberof AppFormGroup
     */ 
    @Prop() iconInfo?:any;

    /**
     * 是否显示标题
     *
     * @type {boolean}
     * @memberof AppFormGroup
     */
    @Prop({ default: true }) isShowCaption!: boolean;

    /**
     * 信息面板模式
     *
     * @type {boolean}
     * @memberof AppFormGroup
     */
    @Prop({ default: false }) isInfoGroupMode!: boolean;

    /**
     * 界面行为组
     *
     * @type {*}
     * @memberof AppFormGroup
     */
    @Prop() uiActionGroup?: any;

    /**
     * 标题栏关闭模式
     * 0: 不支持关闭
     * 1: 默认打开
     * 2： 默认关闭
     *
     * @type {(number | 0 | 1 | 2)} 
     * @memberof AppFormGroup
     */
    @Prop({ default: 0 }) titleBarCloseMode!: number | 0 | 1 | 2;

    /**
     * 收缩内容
     *
     * @type {boolean}
     * @memberof AppFormGroup
     */
    collapseContant: boolean = false;

    /**
     * 计算样式
     *
     * @readonly
     * @type {string[]}
     * @memberof AppFormGroup
     */
    get classes(): string[] {
        return [
            'app-form-group',
            this.isShowCaption && this.collapseContant ? 'app-group-collapse-contant' : '',
            this.isInfoGroupMode ? 'app-info-group-mode' : '',
            Object.is(this.layoutType, 'FLEX') ? 'app-group-flex' : '',
            this.isShowCaption ? 'show-caption' : 'no-caption',
        ];
    }

    /**
     * 标题样式
     *
     * @readonly
     * @type {string}
     * @memberof AppFormGroup
     */
    get titleClass():string{
        return this.titleStyle?this.titleStyle:'';
    }

    /**
     * vue 生命周期
     *
     * @memberof AppFormGroup
     */
    created() {
        this.collapseContant = this.titleBarCloseMode === 2 ? true : false;
    }

    /**
     * 触发收缩
     *
     * @memberof AppFormGroup
     */
    clickCollapse(): void {
        this.collapseContant = !this.collapseContant;
    }

    /**
     * 执行界面行
     *
     * @param {*} $event
     * @memberof AppFormGroup
     */
    doUIAction($event: any, item: any): void {
        this.$emit('groupuiactionclick', { event: $event, item: item });
    }

    /**
     * 操作管理容器
     *
     * @param {*} $event
     * @memberof AppFormGroup
     */
    doManageContainer(){
        this.$emit('managecontainerclick');
    }
}
</script>
<style lang='less'>
@import './app-form-group.less';
</style>